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Amendments to the Claims: 

This listing of claims will replace all prior versions, and listings, of claims in the 
application: 

Listing of Claims: 

Claims 1-2 (canceled) 

3. (original): A method for loop-free multipath routing of data in a network, 
comprising: 

(a) maintaining at each node i in a network, 

(i) a main distance table (MDT) containing Dj and p\ . where D) is 

the distance of node / to destination j and p) is the predecessor to destination 
j on the shortest path from / to j , 

(ii) said MDT further containing, for each destination j , successor set 
S; , feasible distance FD% reported distance RDj , and flags designated as 
changed and report — it , 

(iii) a main link table (MLT) 7" which is the node's view of the network 
and contains links represented by (m, n, d) where (m, n) is a link with cost d , 

(iv) a neighbor distance table (NDT) for neighbor k containing D) k and 

Pj M where D\ k is the distance of neighbor k to j as communicated by * and 
p ! Jk is the predecessor to j on the shortest path from k to j as notified by k > 
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(v) a neighbor link table (NLT)r; which is the view that neighbor k has 
of the network as known to ? and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost l[ of an adjacent 
link to each neighbor k , wherein said cost is infinity if a link is down; and 

(b) in response to receipt of an update message M from a neighbor k , 
detection of a change in cost of an adjacent link to k , or detection of a change in status 
of an adjacent link to k , 

(i) updating the NDT and NLT for neighbor k with links (m, n, d) 

where d = D'^ - D'^ and m = p' ttk , and 

(ii) constructing an MLT for neighbor k by merging topologies T* and 
adjacent links I[ . 

4. (original): A method as recited in claim 3, further comprising: 

(c) for each destination j marked as changed t adding an update entry 

[ j\D* p p'j] to a new message M'; and 

(d) within a finite amount of time, sending message M to each neighbor A . 

5. (original): A method as recited in claim 4, wherein an update message 
comprises: 

at least one update entry; 

said update entry comprising a triplet [j*d,p], where d is the distance of the 
node sending the message to destination j and p is the predecessor on the path to j ; 
and 

flags for synchronization designated as query and reply. 
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6. (original): A method as recited in claim 3, further comprising: 

updating the MLT with link information reported by the neighbor k that offers the 
shortest distance from the node i to the head node m of the link if two or more NLTs 
contain conflicting information of link (m, n). 

7. (original): A method as recited in claim 3 r further comprising: 

after merging topologies T l k and adjacent links l[ , running Dijkstra's shortest 
path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 

8. (original): A method as recited in claim 7, further comprising: 
obtaining distances Dj and predecessors p* } from the MLT. 

9. (original): A method as recited in claim 8, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 

10. (original): A method as recited in claim 3, further comprising: 
computing a successor sets) by, for each destination j , allowing a node i to 

choose a successor having a distance to j as known to / that is less than the distance 
of node /to destination j that is known to a neighbor of node i . 

1 1 . (original): A method as recited in claim 10, further comprising 
synchronizing the exchange of update messages among neighbors using query and 
reply flags contained within the messages. 
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12. (original): A method as recited in claim 1 1 , wherein if a node sends a 
message with a query Hag set, said node must wait until a reply is received from all of 
said node's neighbors before said node Is allowed to send the next update message. 

13. (original): A method as recited in claim 12, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a query flag set. 

14. (original): A method as recited in claim 1 3, wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 
in transit or pending to be processed. 

15. (original): A method as recited in claim 14: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
new distance, said node checks if the distance Dj to any destination j has increased 

above the previously reported distance RD^ ; and 

wherein if no distance has increased, then said node remains in a PASSIVE 

state; 

wherein if a distance has increased, said node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 

16. (previously presented): A method as recited in claim 13: 

wherein a node in an ACTIVE state cannot send any update messages or add 
neighbors to any successor set; 
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wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

17. (original): A method as recited in claim 14: 

wherein if a node receives a message with the query flag set when in PASSIVE 
state, said node modifies said node's tables and sends back an update message with 
the reply flag set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, said node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set. 

18. (original): A method for loop-free multipath routing of data in a network, 
comprising: 

(a) maintaining at each node / in a network, 

(i) a main distance table (MDT) containing D' } and Pj , where D) is 

the distance of node / to destination j and p) is the predecessor to destination 
j on the shortest path from / to / , 

(ii) said MDT further containing , for each destination j 9 successor set 
S'j , feasible distance FD 1 ^ reported distance fuy j% and flags designated as 
changed and report -it , 

(iii) a main link table (MLT) T which is the node's view of the network 
and contains links represented by (m , n, d) where (m , n)\sB link with cost d , 
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(iv) a neighbor distance table (NDT) for neighbor k containing D' Jk and 
p\ k where U k is the distance of neighbor k to j as communicated by k and 
p' Jk is the predecessor to j on the shortest path from k to j as notified by k , 

(v) a neighbor link table (NLT)7;' which is the view that neighbor k has 
of the network as known to / and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost /; of an adjacent 
link to each neighbor k , wherein said cost is infinity if a link is down; 

(b) in response to receipt of an update message M from a neighbor k ( 
detection of a change in cost of an adjacent link to £ , or detection of a change in status 
of an adjacent link to k , 

(i) updating the NDT and NLT for neighbor k with links (m, n, d) 

where d - D* nk - D' mk and m = , and 

(ii) constructing an MLT for neighbor k by merging topologies T k and 
adjacent links l[ ; 

(c) for each destination /marked as changed, adding an update entry 
Py] to a new message M \ and 

(d) within a finite amount of time, sending message M'to each neighbor k . 

19. (original): A method as recited in claim 18, wherein an update message 
comprises: 

at least one update entry; 
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said update entry comprising a triplet [j,d,p], where d is the distance of the 
node sending the message to destination j and p is the predecessor on the path to j ; 
and 

flags for synchronization designated as query and reply . 

20. (original): A method as recited in claim 18, further comprising: 
updating the MLT with link information reported by the neighbor k that offers the 

shortest distance from the node ? to the head node m of the link if two or more 
neighbor link tables contain conflicting information of link (m, n). 

21. (original): A method as recited in claim 18 ( further comprising: 

after merging topologies T{ and adjacent links l[ t running Dijkstra's shortest 
path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 

22. (original): A method as recited in claim 21, further comprising: 
obtaining distances D* } and predecessors p) from the MLT. 

23. (original): A method as recited in claim 22, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 

24. (original): A method for loop-free multipath routing of data in a network, 
comprising: 

(a) maintaining at each node i in a network, 
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(i) a main distance table (MDT) containing D) and p*. , where D) is 
the distance of node f to destination j and Pj is the predecessor to destination 
j on the shortest path from / to / , 

(ii) said MDT further containing, for each destination j , successor set 
Sj, feasible distance FD* J9 reported distance RD' Jt and flags designated as 
changed and report -it, 

(iii) a main link table (MLT) T* which is the node's view of the network 
and contains links represented by (m, n, d) where (m , n ) is a link with cost d , 

(iv) a neighbor distance table (NDT) for neighbor k containing D' Jk and 

Pj k where is the distance of neighbor k to j as communicated by k and 
p' /k is the predecessor to J on the shortest path from k to / as notified by * , 

(v) a neighbor link table (NLT)^' which is the view that neighbor k has 
of the network as known to / and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost V k of an adjacent 
link to each neighbor k , wherein said cost is infinity if a link is down; 

(b) in response to receipt of an update message M from a neighbor k , 
detection of a change in cost of an adjacent link to k , or detection of a change in status 
of an adjacent link to k , 

(i) updating the NDT and NLT for neighbor k with links (m, n $ d) 
where d = - and m = & , 

(ii) constructing an MLT for neighbor k by merging topologies T k and 
adjacent links l[ ; and 
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(c) computing a successor set Sj by, for each destination j , allowing a node 
i to choose a successor having a distance to / as known to / that is less than the 
distance of node /to destination j that is known to a neighbor of node i . 

25. (original): A method as recited in claim 24, further comprising: 
updating the MLT with link information reported by the neighbor k that offers the 

shortest distance from the node i to the head node m of the link if two or more NLTs 
contain conflicting information of link (m, n). 

26. (original): A method as recited in claim 24, further comprising: 

after merging topologies T k and adjacent links V k , running Dijkstra's shortest 

path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 

27. (originaf): A method as recited in claim 26 ( further comprising: 
obtaining distances D) and predecessors p\ from the MLT. 

28. (original): A method as recited in claim 27, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 

29. (original): A method as recited in claim 24 r further comprising 
synchronizing the exchange of update messages among neighbors using query and 
reply flags contained within the messages. 
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30. (original): A method as recited in claim 29, wherein if a node sends a 
message with a query flag set, said node must wait until a reply is received from all of 
said node's neighbors before said node is allowed to send the next update message. 

31. (original): A method as recited in claim 30, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a querying set. 

32. (original): A method as recited in claim 31 , wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 
in transit or pending to be processed. 

33. (original): A method as recited in claim 32: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
new distance, said node checks if the distance D\ to any destination j has increased 

above the previously reported distance RD' f \ and 

wherein if no distance has increased, then said node remains in a PASSIVE 

state; 

wherein if a distance has increased, said node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 

34. (original): A method as recited in claim 31 r wherein a node in an ACTIVE 
cannot send any update messages or add neighbors to any successor set. 

35. (original): A method as recited in claim 31: 
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wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

36. (original): A method as recited in claim 32: 

wherein if a node receives a message with the query flag set when in PASSIVE 
state, said node modifies said node's tables and sends back an update message with 
the reply W^q set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, said node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set 

37. (original): A method for loop-free multipath routing of data in a network, 
comprising: 

(a) maintaining at each node / in a network, 

(i) a main distance table (MDT) containing D\ and p) , where D) is 

the distance of node / to destination j and p) is the predecessor to destination 
j on the shortest path from ? to j , 

(ii) said MDT further containing, for each destination j , successor set 
S' f , feasible distance FZ>), reported distance RD' Jt and flags designated as 
changed and report - it , 

(iii) a main link table (MLT) V which is the node's view of the network 
and contains links represented by (m , n, d) where ( m , n) is a link with cost d , 
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(iv) a neighbor distance table (NDT) for neighbor ft containing D) k and 
p) k where D\ k is the distance of neighbor ft to j as communicated by k and 
p' Jk is the predecessor to j on the shortest path from k to j as notified by k , 

(v) a neighbor link table (NLT)7;' which is the view that neighbor k has 
of the network as known to i and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost l k of an adjacent 
link to each neighbor k , wherein said cost is infinity if a link is down; 

(b) in response to receipt of an update message M from a neighbor k , 
detection of a change in cost of an adjacent link to ft a or detection of a change in status 
of an adjacent link to ft , 

(i) updating the NDT and NLT for neighbor ft with links (m, n, d) 

where d = - D; nk and m = & , 

(ii) constructing an MLT for neighbor ft by merging topologies T k and 
adjacent links l k , and 

(iii) running Dijkstra's shortest path algorithm to find the shortest path 
tree and deletes all links from the MLT that are not in the tree; and 

(c) computing a successor sets} by, for each destination j , allowing a node 
/ to choose a successor having a distance to j as known to i that is less than the 
distanoe of node no destination j that is known to a neighbor of node i . 

38. (original): A method as recited in claim 37, further comprising: 

updating the MLT with link information reported by the neighbor ft that offers the 

shortest distance from the node / to the head node m of the link if two or more NLTs 

contain conflicting information of link (m , n). 
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39. (original): A method as recited in claim 38, further comprising: 
obtaining distances £>} and predecessors p l s from the MLT. 

40. (original): A method as recited in claim 39, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 

41. (original): A method as recited in claim 37, further comprising 
synchronizing the exchange of update messages among neighbors using query and 
reply flags contained within the messages. 

42. (original): A method as recited in claim 41, wherein if a node sends a 
message with a query flag set, said node must wait until a reply is received from all of 
said node's neighbors before said node is allowed to send the next update message. 

43. (original): A method as recited in claim 42, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a query flag set. 

44. (original): A method as recited in claim 43, wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 
in transit or pending to be processed. 

45. (original): A method as recited in claim 44: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
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new distance, said node checks if the distance D\ to any destination j has increased 
above the previously reported distance RD) ; and 

wherein if no distance has increased, then said node remains in a PASSIVE 

state; 

wherein if a distance has increased, said node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 

46. (original): A method as recited in claim 43, wherein a node in an ACTIVE 
cannot send any update messages or add neighbors to any successor set 

47. (original): A method as recited in claim 43: 

wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

48. (original); A method as recited in claim 44: 

wherein if a node receives a message with the query flag set when in PASSIVE 
state, said node modifies said node's tables and sends back an update message with 
the reply flag set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, said node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set. 
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49. (original): A method for loop-free muttipath routing of data in a network, 
comprising: 

(a) maintaining at each node / in a network, 

(i) a main distance table (MDT) containing £>; and p\ > where D) is 

the distance of node / to destination j and p) is the predecessor to destination 
j on the shortest path from / to ; , 

(ii) said MDT further containing, for each destination j , successor set 
S'j , feasible distance FD^ , reported distance RD' Jt and flags designated as 
changed and report -it, 

(iii) a main link table (MLT) T l which is the node's view of the network 
and contains links represented by (m , n , d) where (m , « J is a link with cost d , 

(fv) a neighbor distance table (NDT) for neighbor k containing D* jk and 

p' Jk where D' fk is the distance of neighbor k to j as communicated by k and 
p' jk is the predecessor to j on the shortest path from k to j as notified by * , 

(v) a neighbor link table (NLT)r; which is the view that neighbor k has 
of the network as known to i and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost t' k of an adjacent 
link to each neighbor k , wherein said cost is infinity if a link is down; 

(b) in response to receipt of an update message M from a neighbor A, 
detection of a change in cost of an adjacent link to k , or detection of a change in status 
of an adjacent link to k , 

(i) updating the NDT and NLT for neighbor k with links (m, n, d) 

where d = - D* ink and m = p 1 ^ , 
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(ii) constructing an MLT for neighbor k by merging topologies T* k and 
adjacent links l[ ; 

(c) computing a successor sets', by, for each destination j , allowing a node 
i to choose a successor having a distance to j as known to i that is less than the 
distance of node /to destination ./that is known to a neighbor of node i ; and 

(d) synchronizing the exchange of update messages among neighbors using 
query and reply flags contained within the messages. 

50. (original): A method as recited in claim 49, further comprising: 
updating the MLT with link information reported by the neighbor k that offers the 

shortest distance from the node / to the head node m of the link if two or more NLTs 
contain conflicting information of link (m t n). 

51. (original): A method as recited in claim 49, further comprising: 

after merging topologies T{ and adjacent links l[ , running Dijkstra's shortest 
path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 

52. (original): A method as recited in claim 51, further comprising: 
obtaining distances D) and predecessors p x } from the MLT. 

53. (original): A method as recited in claim 52, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 
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54. (original): A method as recited in claim 49, wherein if a node sends a 
message with a queryflag set, said node must wait until a reply is received from all of 
said node's neighbors before said node is allowed to send the next update message. 

55. (original); A method as recited in claim 54, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a query Hag set. 

56. (original): A method as recited in claim 55, wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 
in transit or pending to be processed. 

57. (original): A method as recited in claim 56: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
new distance, said node checks if the distance D) to any destination j has increased 

above the previously reported distance RD) ; and 

wherein if no distance has increased, then said node remains in a PASSIVE 

state; 

wherein if a distance has increased, said node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 

58. (original): A method as recited in claim 55, wherein a node in an ACTIVE 
cannot send any update messages or add neighbors to any successor set. 

59. (original): A method as recited in claim 55: 
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wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

60. (original): A method as recited in claim 56: 

wherein if a node receives a message with the query flag set when in PASSIVE 
State, said node modifies said node's tables and sends back an update message with 
the reply flag set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, said node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set. 
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